import java.util.HashMap;
import java.util.Map;

public class SubarraySum {
    // 和为k的子数组
    // https://leetcode.cn/problems/subarray-sum-equals-k/?envType=study-plan-v2&envId=top-100-liked
    public int subarraySum(int[] nums, int k) {
        // 前缀和的思想
        Map<Integer, Integer> map = new HashMap<>();
        map.put(0,1);
        int ret = 0;
        int sum = 0;
        for (int num : nums) {
            sum += num;
            ret += map.getOrDefault(sum-k, 0);
            map.put(sum, map.getOrDefault(sum, 0) + 1);
        }
        return ret;
    }
}
